package model

import (
	"gorm.io/driver/mysql"
	"gorm.io/gorm"
)

var db *gorm.DB

func InitDb() error {
	var err error
	db, err = gorm.Open(mysql.New(mysql.Config{
		DSN:                       "root:shizai88@tcp(127.0.0.1:3306)/smmf?charset=utf8&parseTime=True&loc=Local", // DSN data source name
		DefaultStringSize:         256,                                                                            // string 类型字段的默认长度
		DisableDatetimePrecision:  true,                                                                           // 禁用 datetime 精度，MySQL 5.6 之前的数据库不支持
		DontSupportRenameIndex:    true,                                                                           // 重命名索引时采用删除并新建的方式，MySQL 5.7 之前的数据库和 MariaDB 不支持重命名索引
		DontSupportRenameColumn:   true,                                                                           // 用 `change` 重命名列，MySQL 8 之前的数据库和 MariaDB 不支持重命名列
		SkipInitializeWithVersion: false,                                                                          // 根据当前 MySQL 版本自动配置
	}), &gorm.Config{})

	db = db.Debug()
	sqlDB, err := db.DB()
	sqlDB.SetMaxOpenConns(5)

	if err != nil {
		return err
	}

	//err = db.AutoMigrate(&UserDb{}, &ArticleDb{}, &LikeDb{})
	if err != nil {
		return err
	}
	return nil
}
